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System And Method For Managing Data Transmissions From A TFTP 
Server By Specifying A Maximum Bandwidth 

Field of the Invention 

The invention relates to a system and method for transmitting data. More particularly, 
5 the invention relates to a system and method for delaying transmission of data packets from a 
trivial file transfer protocol (TFTP) server by specifying a maximum bandwidth to use for a data 
transmission. 



Background of the Invention 

fUO The TFTP is known. The TFTP enables devices, for example, cable modems, to receive 

S configuration files from a server at start-up. The TFTP operates on a user datagram protocol 
(UDP) to obtain configuration files. At start-up, a device typically determines an Internet 
m ' protocol (IP) address for the device and then obtains configuration files using the TFTP. The 
O • steps used by a device for obtaining configuration files typically conform to the Cablelabs 
15 certified'^'^ cable modem project, formerly known as Data Over Cable Service Interface 
Specification (DOCSIS'^^. The Cablelabs Certified™ cable modem project defines interface 
requirements for cable modems involved in high-speed data distribution over cable television 
system networks. The Cablelabs Certified™ cable modem project may be used as a standard for 
obtaining configuration files using the TFTP. 
20 Devices such as cable modems are typically an always-on device. That is, the device may 

be always powered-on. Thus, if a power outage occurs and power is restored substantially 
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simultaneously, multiple cable modems may request configuration files substantially 
simultaneously from a TFTP server if the cable modems power is restored substantially 
simultaneously. This may result in an overload at the TFTP server. The TFTP server may 
receive multiple configuration file requests and be unable to process each request. As 
5 configuration file requests are sent to the TFTP server, the responses may be stored in buffers as 
the response is relayed by routers and other networking equipment to the cable modem. If 
multiple responses are transmitted substantially simultaneously, the buffer may reach capacity 
before all responses are sent. This may result in responses being lost, time-outs occurring. 



s| retransmission requests from cable modems that do not receive a reply to a request within a 

; : » 

PlO predetermined period of time, or dropped connections. This is inefficient. 



Requests for configuration files using the TFTP may be transmitted to a TFTP server. 
The TFTP server may permit multiple sessions to operate simultaneously. A session may be a 
communication from one cable modem to the TFTP server. Therefore, multiple cable modems 
may request configuration files from the TFTP server substantially simultaneously. 



Therefore, data transmissions that include sending packets of data from a TFTP server may 
transmit the packets faster than an available bandwidth can sustain, for example, if multiple 
requests are received substantially simultaneously by the TFTP server. This may result in 
packets being lost, time-outs, retransmissions, or dropped connections. 
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Data transmissions using the TFTP typically are not limited in transmission rates. 
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These and other drawbacks exist. 
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Summary of the Invention 

The invention solving these and other problems relates to a system and method for 
delaying data transmissions from a TFTP server. The system enables a system administrator, for 
example, a cable company system administrator, to specify a maximum bandwidth, and possibly, 
a maximum number of sessions, for use in sending data transmissions. The system administrator 
may specify a maximum bandwidth and maximum number of sessions for a data transmission. 
Based on the maximum bandwidth and/or number of sessions, the system may calculate a delay 
for sending a data transmission. Therefore, each data transmission may be delayed until a 
predetermined time. This reduces a number of data transmissions that may be transmitted within 
^"10 a given period of time. Therefore, the data transmissions sent may not exceed a predetermined 
Z available bandwidth, thus reducing a number of packet losses, time-outs, retransmissions, 
=i dropped connections or other problems that may occur. 

-a 

i Brief Description of the Drawings 

1 5 FIG. 1 is a schematic block diagram of a method for transmitting data transmissions 

according to one embodiment of the invention. 

FIG. 2 is a schematic block diagram of a method for delaying data transmissions from a 
TFTP server according to one embodiment of the invention. 

FIG. 3 is a schematic block diagram of a system for delaying data transmissions from a 
20 TFTP server according to one embodiment of the invention. 

FIG. 4 is schematic block diagram of an overall cable network system according to one 
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embodiment of the invention. 

Detailed Description of the Preferred Embodimeats 

The invention relates in one regard to a system and method for delaying data 
5 transmissions from a TFTP server. The invention enables a system administrator to specify a 
maximum bandwidth, or other parameter, for at least one data transmission. Based on the 
maximum bandwidth, a delay may be calculated for sending the data transmission. 

FIG. 1 illustrates a method for sending data transmissions according to one embodiment 
sj of the invention. The method may be used with end-user devices, for example, cable modems. 
OlO At start-up, for example, when a cable modem is tumed-on, the cable modem may initiate a 
connection to, for example, a Dynamic Host Configuration Protocol (DHCP) server in step 102. 
u After initiating a connection, the cable modem may determine an Litemet protocol (ff ) address 
N= for the modem in step 104. The cable modem may request its IP address, an IP address for a 
y TFTP server storing configuration files for the modem, and a name(s) of the configuration file(s) 
1 5 for the modem from DHCP server. The DHCP server may return this and/or other information to 
the cable modem enabling configuration of the cable modem. The cable modem may then 
request the configuration file(s) from the TFTP server in step 106 for configuring the cable 
modem. The configuration files enable the cable modem to communicate with the TFTP server. 
The cable modem may then become operafional in step 110. A cable modem user may then use 
20 the cable modem to connect to, for example, the Internet. 



FIG. 2 illustrates a method for delaying data transmissions from a server according to one 
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embodiment of the invention. The method may include an enable system administrator to 
specify maximum bandwidth step 202. In step 202, the system administrator may specify the 
maximum bandwidth that a TFTP server may use for sending a data transmission. The system 
administrator may be, for example, a system administrator of a service provider that provides 
5 Internet access to an end-user. Step 204 may be used to enable a system administrator to specify 
a maximum number of sessions that may operate substantially simultaneously. The method may 
also include a determine maximum bandwidth step 206. In step 206, a maximum bandwidth to 
~ be used for transmitting a data transmission may be determined. The maximum bandwidth may 
S| be a maximum specified by a system administrator in step 202, a default maximum bandwidth 
^1 0 set by a system administrator or other. 



A determine maximum number of sessions step 208 may be used to determine a 
maximum number of sessions that may operate substantially simultaneously. The maximum 
number of sessions may be specified by a system administrator or other user, a default maximum 
number of sessions set by a system administrator or other manner of determining a maximum 



15 number of sessions. After determining the maximum number of sessions, a delay for sending a 
data transmission may be calculated in step 210. Step 210 may calculate a delay based on the 
maximum number of sessions, a time delay, a number of data transmissions, or other method. 
According to one embodiment of the invention, step 210 calculates a delay using a formula of: 
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Formula 1 : D = 1000 * (1 / (B * 1,000,000)) * P * 8 * S 
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where D is the delay in milliseconds, B is a specified bandwidth in megabits per second, 
P is a data packet sized in bytes, 8 is a conversion factor fi-om bits to bytes, and S is a maximum 
number of sessions. 

For cable modems using the TFTP, P may be 512 bytes which is the packet size fixed by 
5 the TFTP. The bandwidth B and maximum nimiber of sessions S may be specified by a system 
administrator for establishing a delay in sending a data sent. Based on the data packet size, 
maximum bandwidth, and maximum number of sessions, a delay may be calculated in step 210 
to determine when a data transmission should be transmitted. If the delay is a time delay, for 
SJ example, in milliseconds, the data transmission may not be transmitted until the delay time has 
yjlO expired. After the delay has expired, the data transmission may then be transmitted using step 



According to another embodiment, the delay may be based on a number of data 
transmissions sent. For example, a data transmission may not occur until a predetermined 
number of data transmissions have been sent. A data transmission may be delayed until, for 



15 example, fifteen (15) data transmissions have been sent. Additionally, a data transmission may 

be delayed until fifteen (15) data transmissions have been sent within a predetermined time 

period, for example, one (1) second. 

FIG. 3 illustrates a system for delaying data transmissions fi'om a TFTP server 302 

according to one embodiment of the invention. TFTP server 302 may include a maximum 
20 bandwidth specifying module 304, session specifying module 306, maximum bandwidth 

determining module 308, maximum number of sessions specifying module 310, delayed 



212. 
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determining module 312, and transmitting module 314. 

Maximum bandwidth specifying module 304 may enable a system administrator to 
specify a maximum bandwidth for sending a data transmission. The maximum bandwidth may 
be specified as a percentage of bandwidth available, for example, ten (10) percent, a fixed 
5 number, for example, one (1) megabit per second, or other mechanism. If a system administrator 
does not specify a maximum bandwidth, a default maximum bandwidth set by, for example, a 
system administrator may be used. Session specifying module 306 may be used to enable a 
system administrator to specify a maximum number of sessions that may be operated 

Sj simultaneously. A system administrator may specify a maximum or default number of sessions 

yi 0 that may be operated simultaneously. 

^ Maximum bandwidth determining module 308 may be used to determine a maximum 

^ bandwidth to be used in sending a data transmission. The maximum bandwidth may be a 
M maximum bandwidth specified by the system administrator in step 304, a default bandwidth 
y specified by a system administrator or other user, or other mechanism. Maximum number of 
15 sessions specifying module 310 may identify a maximum nimiber of sessions that may be 
operated substantially simultaneously. The maximum number of sessions specified may be the 
number of sessions specified by a system administrator using maximimi nimiber of sessions 
specifying module 306, a default maximum number of sessions specified by a system 
administrator or other user, or other mechanism. 
20 Delay determining module 312 may determine a delay for transmitting the data 

transmission according to the maximum bandwidth and number of sessions specified. The delay 
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may be calculated as described above. After determining the delay, transmitting module 314 
may be used to transmit the data transmission after the delay calculated has expired. 

FIG. 4 is a schematic block diagram of a cable network system. The system may include 
one or more cable modems 402a-402n, head-end 404, and Internet 406. Head-end 404 may 
5 include a DHCP server 408 and a TFTP server 410. Cable modems 402a-402n may be in 
communication with head-end 404 over, for example, a cable network. Cable modems 402a- 
402n may request one or more data transmissions from head-end 404. For example, at start-up, 
^ cable modems 402a-402n may request initialization information from head-end 404. Head-end 
%j 404 may receive the request for initialization information and return the initialization information 
r=10 using DHCP server 408. DHCP server 408 may respond to the request for initiahzation 
^ information by transmitting to cable modems 402a-402n an IP address for the cable modem 
u requesting initialization information, the ff address for TFTP server 410, and the name of a 
M" configuration file for the cable modem requesting the initialization information. Cable modems 
y 402a-402n may then request a configuration file from TFTP server 410 using the IP address for 
15 TFTP server 410 and the name of the configuration file received from DHCP server 408. Cable 
modems 402a-402n may then use the configuration files for configuration purposes. 

Head-end 404 may also enable cable modems 402a-402n to transmit requests via Internet 
406. Cable modems 402a-402n may be used to enable high-speed Internet access to one or more 
web sites. Cable modems 402a-402n may be in communication with or provided at one or more 
20 clients (not shown). Internet access may be provided using any known method. 

The foregoing description for a system and method for delaying data transmissions from 
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a server is illustrative, and changes in the above construction and sequences of operation may 
occur to persons skilled in the art. For example, although multiple modules are shovra for 
carrying out the invention, additional or fewer modules may be used and multiple modules may 
be positioned in various locations. Additionally, the steps for carrying out the invention may be 
5 supplemented, reduced, or rearranged. Although the invention has been described in terms of a 
TFTP server and cable modem devices, the invention may be used with any type of server or 
end-user device. Furthermore, the invention may be used with data transmissions other than 
configuration file requests and parameters specified by a system administrator may be specified 
SJ by an end-user or other user. Therefore, the scope of the invention is intended to be limited only 
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ffjlO by the following claims. 
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